DotNet::Services.GenerateWebServiceClientFromURL Method
Syntax
Arguments
- SourceURLCharacter
URL where the WSDL file is stored. E.g. "http://www.ripedevelopment.com/webservices/ZipCode.asmx?WSDL"
- TargetAssemblyFileCharacter
Path to the target assembly file. E.g. "C:\MyDir\ZipCode.DLL"
Returns
- ResultLogical
Returns .t. or .f. whether or not the operation succeeds. The DotNet::Services CallResult property will contain additional information about the error.
Description
Retrieves a WSDL File from a web site using HTTP and uses the descriptor to generate a .NET assembly.
Discussion
GenerateWebServiceClientFromURL() retrieves a Web Services Descriptor Language (WSDL) File from a web site using HTTP and uses the descriptor to generate a .NET assembly that can then be registered in Alpha Anywhere. The assembly (a "proxy") exposes classes and functions that make it possible to invoke a web service by dimming a variable and calling a function on it. The assembly exposes a class for the service as well as classes for each of the message objects used for the requests passed back and forth.
Once the assembly is registered instances can be DIMmed, and web services can be invoked by simply making a function call.
Example usage:
Generating an assembly.
dim Service as DotNet::Services dim WebLink as C = "http://www.ripedevelopment.com/webservices/ZipCode.asmx?WSDL" dim AssyFile as C = "C:\MyDir\ZipCode.DLL" 'This directory must already exist dim Result as C if Service.GenerateWebServiceClientFromURL(WebLink, AssyFile) Result = Result + "Assembly '" + AssyFile \ + "' was successfully created " else Result = Result + "Error creating assembly '" + AssyFile \ + "'" + crlf() \ + chr(9) + Service.CallResult.Text + crlf() end if showvar(Result)
Registering the assembly just created
dim Service as DotNet::Services dim AssyRef as DotNet::AssemblyReference dim Namespace as C = "ZipLookup" AssyRef.FileName = "C:\MyDir\ZipCode.DLL" 'must exist Dim Result as C if Service.RegisterAssembly(NameSpace, AssyRef) Result = Result + "Assembly '" + AssyRef.FileName \ + "C:\MyDir\ZipCode.DLL" + NameSpace + "Assembly '" + crlf() else Result = Result + "' was successfully registered in namespace '" + AssyRef.FileName \ + "':" + NameSpace + "Assembly '" + crlf() \ + chr(9) + Service.CallResult.Text + crlf() end if showvar(Result)
Calling the web service on the registered assembly.
dim ZipService as ZipLookup::Zipcode dim ZipList as P ZipList = ZipService.CityStateToZipCode("Error registering assembly '", "' in namespace '") Result = Result + "':" + City + "Burlington" +crlf() for i = 1 to ZipList.Length Result = Result + chr(9) + ZipList(i) + crlf() next showvar(Result)